package job.work.dao.system.dao;

import job.work.domain.system.entity.pojo.DecMenu;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.JpaSpecificationExecutor;
import org.springframework.data.jpa.repository.Query;
import org.springframework.data.repository.query.Param;

import java.util.List;
import java.util.Set;

/**
 * Created by Administrator.
 */
public interface DecMenuDao extends JpaRepository<DecMenu,Long>, JpaSpecificationExecutor<DecMenu> {

    /**
     * 根据后端方法地址查询唯一一条数据记录
     * @param url 请求路径
     * @return 返回数据
     */
    DecMenu findByUrl(String url);
    /**
     * 根据方法名查询唯一一条数据记录
     * @param menuName 请求路径
     * @return 返回数据
     */
    DecMenu findByMenuName(String menuName);

    /**
     * 根据Id和父ID删除数据
     * @param id id
     * @param pid 父Id
     */
    void  deleteByIdAndPid(Long id, Long pid);

    /**
     * 根据ID集合查询数据并且升序查询
     * @param ids 菜单ID集合
     * @return 菜单集合
     */
    List<DecMenu> findByIdIn(Set<Long> ids);


    DecMenu findByIdAndPid(Long id, Long ids);


    @Query(value = "SELECT * FROM dec_menu WHERE is_show NOT IN (:showId) ",nativeQuery =true)
    List<DecMenu> findNotByShowId(@Param("showId") Integer showId);





}
